class Vue {
    constructor(options){
        //通过属性保存选项的数据
        this.$options = options
        this.$data = options.data
        this.$methods = options.methods
        this.$el = typeof options.el === 'string' ? document.querySelector(options.el) : el
        //2. 把data中的成员转换成getter、setter 注入到vue实例中
        this._proxyData(this.$data)
        //3.调用observer对象，监听数据变化
        new Observer(this.$data)
        //4. 调用compiler对象 解析指令和差值表达式
        new Compiler(this)
    }
    _proxyData(data){
        Object.keys(data).forEach(key => {
            Object.defineProperty(this, key , {
                configurable: true,
                enumerable: true,
                get(){
                    return data[key]
                },
                set(nvalue){
                    if(nvalue === data[key]){
                        return
                    }
                    data[key] = nvalue
                }
            })
        })
    }
}